<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
<title>プラグインの記述</title>
<meta name="generator" content="DocBook XSL Stylesheets V1.75.1">
<link rel="home" href="index.html" title="Smarty マニュアル">
<link rel="up" href="plugins.html" title="Chapter 16. プラグインによる Smarty の拡張">
<link rel="prev" href="plugins.naming.conventions.html" title="命名規約">
<link rel="next" href="plugins.functions.html" title="テンプレート関数プラグイン">
</head>
<body bgcolor="white" text="black" link="#0000FF" vlink="#840084" alink="#0000FF">
<div class="navheader">
<table width="100%" summary="Navigation header">
<tr><th colspan="3" align="center">プラグインの記述</th></tr>
<tr>
<td width="20%" align="left">
<a accesskey="p" href="plugins.naming.conventions.html">Prev</a> </td>
<th width="60%" align="center">Chapter 16. プラグインによる Smarty の拡張</th>
<td width="20%" align="right"> <a accesskey="n" href="plugins.functions.html">Next</a>
</td>
</tr>
</table>
<hr>
</div>
<div class="sect1" title="プラグインの記述">
<div class="titlepage"><div><div><h2 class="title" style="clear: both">
<a name="plugins.writing"></a>プラグインの記述</h2></div></div></div>
<p>
     プラグインは Smarty によってファイルシステムから自動的に読み込まれるか、
     register_* API 関数のうちの１つを経由して動的に登録する事ができます。
     また、それらは unregister_* API 関数を使う事によって未登録にする事ができます。
    </p>
<p>
     動的に登録されるプラグインについてはプラグイン関数の命名規約に従う必要はありません。
    </p>
<p>
     Smarty にバンドルされたいくらかのプラグインに関する場合と同様に、
     プラグインが別のプラグインによって提供される機能に依存する場合は次の方法で必要とされるプラグインを読み込みます。
    </p>
<pre class="programlisting">

&lt;?php
require_once $smarty-&gt;_get_plugin_filepath('function', 'html_options');
?&gt;

    </pre>
<p>
     基本的に、Smarty のオブジェクトは常に最後のパラメータとしてプラグインに渡されます。
     ただし、例外が２つあります。
     </p>
<div class="itemizedlist"><ul class="itemizedlist" type="disc">
<li class="listitem"><p>
     変数の修飾子は Smarty オブジェクトを渡しません。
     </p></li>
<li class="listitem"><p>
     ブロックの場合は Smarty オブジェクトの後に <em class="parameter"><code>$repeat</code></em>
     が渡されます。これは、以前のバージョンの Smarty
     との後方互換性を保つためのものです。
     </p></li>
</ul></div>
</div>
<div class="navfooter">
<hr>
<table width="100%" summary="Navigation footer">
<tr>
<td width="40%" align="left">
<a accesskey="p" href="plugins.naming.conventions.html">Prev</a> </td>
<td width="20%" align="center"><a accesskey="u" href="plugins.html">Up</a></td>
<td width="40%" align="right"> <a accesskey="n" href="plugins.functions.html">Next</a>
</td>
</tr>
<tr>
<td width="40%" align="left" valign="top">命名規約 </td>
<td width="20%" align="center"><a accesskey="h" href="index.html">Home</a></td>
<td width="40%" align="right" valign="top"> テンプレート関数プラグイン</td>
</tr>
</table>
</div>
</body>
</html>
